package com.lucky.ebidding.model;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class ZbInfoExample {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    public ZbInfoExample() {
        oredCriteria = new ArrayList<>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIdIsNull() {
            addCriterion("ID is null");
            return (Criteria) this;
        }

        public Criteria andIdIsNotNull() {
            addCriterion("ID is not null");
            return (Criteria) this;
        }

        public Criteria andIdEqualTo(Integer value) {
            addCriterion("ID =", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotEqualTo(Integer value) {
            addCriterion("ID <>", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThan(Integer value) {
            addCriterion("ID >", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("ID >=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThan(Integer value) {
            addCriterion("ID <", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThanOrEqualTo(Integer value) {
            addCriterion("ID <=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdIn(List<Integer> values) {
            addCriterion("ID in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotIn(List<Integer> values) {
            addCriterion("ID not in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdBetween(Integer value1, Integer value2) {
            addCriterion("ID between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotBetween(Integer value1, Integer value2) {
            addCriterion("ID not between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andProjectIdIsNull() {
            addCriterion("project_id is null");
            return (Criteria) this;
        }

        public Criteria andProjectIdIsNotNull() {
            addCriterion("project_id is not null");
            return (Criteria) this;
        }

        public Criteria andProjectIdEqualTo(String value) {
            addCriterion("project_id =", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdNotEqualTo(String value) {
            addCriterion("project_id <>", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdGreaterThan(String value) {
            addCriterion("project_id >", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdGreaterThanOrEqualTo(String value) {
            addCriterion("project_id >=", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdLessThan(String value) {
            addCriterion("project_id <", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdLessThanOrEqualTo(String value) {
            addCriterion("project_id <=", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdLike(String value) {
            addCriterion("project_id like", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdNotLike(String value) {
            addCriterion("project_id not like", value, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdIn(List<String> values) {
            addCriterion("project_id in", values, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdNotIn(List<String> values) {
            addCriterion("project_id not in", values, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdBetween(String value1, String value2) {
            addCriterion("project_id between", value1, value2, "projectId");
            return (Criteria) this;
        }

        public Criteria andProjectIdNotBetween(String value1, String value2) {
            addCriterion("project_id not between", value1, value2, "projectId");
            return (Criteria) this;
        }

        public Criteria andTitleIsNull() {
            addCriterion("TITLE is null");
            return (Criteria) this;
        }

        public Criteria andTitleIsNotNull() {
            addCriterion("TITLE is not null");
            return (Criteria) this;
        }

        public Criteria andTitleEqualTo(String value) {
            addCriterion("TITLE =", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleNotEqualTo(String value) {
            addCriterion("TITLE <>", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleGreaterThan(String value) {
            addCriterion("TITLE >", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleGreaterThanOrEqualTo(String value) {
            addCriterion("TITLE >=", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleLessThan(String value) {
            addCriterion("TITLE <", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleLessThanOrEqualTo(String value) {
            addCriterion("TITLE <=", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleLike(String value) {
            addCriterion("TITLE like", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleNotLike(String value) {
            addCriterion("TITLE not like", value, "title");
            return (Criteria) this;
        }

        public Criteria andTitleIn(List<String> values) {
            addCriterion("TITLE in", values, "title");
            return (Criteria) this;
        }

        public Criteria andTitleNotIn(List<String> values) {
            addCriterion("TITLE not in", values, "title");
            return (Criteria) this;
        }

        public Criteria andTitleBetween(String value1, String value2) {
            addCriterion("TITLE between", value1, value2, "title");
            return (Criteria) this;
        }

        public Criteria andTitleNotBetween(String value1, String value2) {
            addCriterion("TITLE not between", value1, value2, "title");
            return (Criteria) this;
        }

        public Criteria andContentIsNull() {
            addCriterion("CONTENT is null");
            return (Criteria) this;
        }

        public Criteria andContentIsNotNull() {
            addCriterion("CONTENT is not null");
            return (Criteria) this;
        }

        public Criteria andContentEqualTo(String value) {
            addCriterion("CONTENT =", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentNotEqualTo(String value) {
            addCriterion("CONTENT <>", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentGreaterThan(String value) {
            addCriterion("CONTENT >", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentGreaterThanOrEqualTo(String value) {
            addCriterion("CONTENT >=", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentLessThan(String value) {
            addCriterion("CONTENT <", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentLessThanOrEqualTo(String value) {
            addCriterion("CONTENT <=", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentLike(String value) {
            addCriterion("CONTENT like", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentNotLike(String value) {
            addCriterion("CONTENT not like", value, "content");
            return (Criteria) this;
        }

        public Criteria andContentIn(List<String> values) {
            addCriterion("CONTENT in", values, "content");
            return (Criteria) this;
        }

        public Criteria andContentNotIn(List<String> values) {
            addCriterion("CONTENT not in", values, "content");
            return (Criteria) this;
        }

        public Criteria andContentBetween(String value1, String value2) {
            addCriterion("CONTENT between", value1, value2, "content");
            return (Criteria) this;
        }

        public Criteria andContentNotBetween(String value1, String value2) {
            addCriterion("CONTENT not between", value1, value2, "content");
            return (Criteria) this;
        }

        public Criteria andUserIdIsNull() {
            addCriterion("USER_ID is null");
            return (Criteria) this;
        }

        public Criteria andUserIdIsNotNull() {
            addCriterion("USER_ID is not null");
            return (Criteria) this;
        }

        public Criteria andUserIdEqualTo(Integer value) {
            addCriterion("USER_ID =", value, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdNotEqualTo(Integer value) {
            addCriterion("USER_ID <>", value, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdGreaterThan(Integer value) {
            addCriterion("USER_ID >", value, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("USER_ID >=", value, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdLessThan(Integer value) {
            addCriterion("USER_ID <", value, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdLessThanOrEqualTo(Integer value) {
            addCriterion("USER_ID <=", value, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdIn(List<Integer> values) {
            addCriterion("USER_ID in", values, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdNotIn(List<Integer> values) {
            addCriterion("USER_ID not in", values, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdBetween(Integer value1, Integer value2) {
            addCriterion("USER_ID between", value1, value2, "userId");
            return (Criteria) this;
        }

        public Criteria andUserIdNotBetween(Integer value1, Integer value2) {
            addCriterion("USER_ID not between", value1, value2, "userId");
            return (Criteria) this;
        }

        public Criteria andCompanyNameIsNull() {
            addCriterion("company_name is null");
            return (Criteria) this;
        }

        public Criteria andCompanyNameIsNotNull() {
            addCriterion("company_name is not null");
            return (Criteria) this;
        }

        public Criteria andCompanyNameEqualTo(String value) {
            addCriterion("company_name =", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameNotEqualTo(String value) {
            addCriterion("company_name <>", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameGreaterThan(String value) {
            addCriterion("company_name >", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameGreaterThanOrEqualTo(String value) {
            addCriterion("company_name >=", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameLessThan(String value) {
            addCriterion("company_name <", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameLessThanOrEqualTo(String value) {
            addCriterion("company_name <=", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameLike(String value) {
            addCriterion("company_name like", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameNotLike(String value) {
            addCriterion("company_name not like", value, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameIn(List<String> values) {
            addCriterion("company_name in", values, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameNotIn(List<String> values) {
            addCriterion("company_name not in", values, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameBetween(String value1, String value2) {
            addCriterion("company_name between", value1, value2, "companyName");
            return (Criteria) this;
        }

        public Criteria andCompanyNameNotBetween(String value1, String value2) {
            addCriterion("company_name not between", value1, value2, "companyName");
            return (Criteria) this;
        }

        public Criteria andFileIdIsNull() {
            addCriterion("file_id is null");
            return (Criteria) this;
        }

        public Criteria andFileIdIsNotNull() {
            addCriterion("file_id is not null");
            return (Criteria) this;
        }

        public Criteria andFileIdEqualTo(Integer value) {
            addCriterion("file_id =", value, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdNotEqualTo(Integer value) {
            addCriterion("file_id <>", value, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdGreaterThan(Integer value) {
            addCriterion("file_id >", value, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("file_id >=", value, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdLessThan(Integer value) {
            addCriterion("file_id <", value, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdLessThanOrEqualTo(Integer value) {
            addCriterion("file_id <=", value, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdIn(List<Integer> values) {
            addCriterion("file_id in", values, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdNotIn(List<Integer> values) {
            addCriterion("file_id not in", values, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdBetween(Integer value1, Integer value2) {
            addCriterion("file_id between", value1, value2, "fileId");
            return (Criteria) this;
        }

        public Criteria andFileIdNotBetween(Integer value1, Integer value2) {
            addCriterion("file_id not between", value1, value2, "fileId");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNull() {
            addCriterion("CREATE_TIME is null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNotNull() {
            addCriterion("CREATE_TIME is not null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeEqualTo(Date value) {
            addCriterion("CREATE_TIME =", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotEqualTo(Date value) {
            addCriterion("CREATE_TIME <>", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThan(Date value) {
            addCriterion("CREATE_TIME >", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("CREATE_TIME >=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThan(Date value) {
            addCriterion("CREATE_TIME <", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThanOrEqualTo(Date value) {
            addCriterion("CREATE_TIME <=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIn(List<Date> values) {
            addCriterion("CREATE_TIME in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotIn(List<Date> values) {
            addCriterion("CREATE_TIME not in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeBetween(Date value1, Date value2) {
            addCriterion("CREATE_TIME between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotBetween(Date value1, Date value2) {
            addCriterion("CREATE_TIME not between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeIsNull() {
            addCriterion("MODIFY_TIME is null");
            return (Criteria) this;
        }

        public Criteria andModifyTimeIsNotNull() {
            addCriterion("MODIFY_TIME is not null");
            return (Criteria) this;
        }

        public Criteria andModifyTimeEqualTo(Date value) {
            addCriterion("MODIFY_TIME =", value, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeNotEqualTo(Date value) {
            addCriterion("MODIFY_TIME <>", value, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeGreaterThan(Date value) {
            addCriterion("MODIFY_TIME >", value, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("MODIFY_TIME >=", value, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeLessThan(Date value) {
            addCriterion("MODIFY_TIME <", value, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeLessThanOrEqualTo(Date value) {
            addCriterion("MODIFY_TIME <=", value, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeIn(List<Date> values) {
            addCriterion("MODIFY_TIME in", values, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeNotIn(List<Date> values) {
            addCriterion("MODIFY_TIME not in", values, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeBetween(Date value1, Date value2) {
            addCriterion("MODIFY_TIME between", value1, value2, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andModifyTimeNotBetween(Date value1, Date value2) {
            addCriterion("MODIFY_TIME not between", value1, value2, "modifyTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeIsNull() {
            addCriterion("PROJECT_START_TIME is null");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeIsNotNull() {
            addCriterion("PROJECT_START_TIME is not null");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeEqualTo(Date value) {
            addCriterion("PROJECT_START_TIME =", value, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeNotEqualTo(Date value) {
            addCriterion("PROJECT_START_TIME <>", value, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeGreaterThan(Date value) {
            addCriterion("PROJECT_START_TIME >", value, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("PROJECT_START_TIME >=", value, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeLessThan(Date value) {
            addCriterion("PROJECT_START_TIME <", value, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeLessThanOrEqualTo(Date value) {
            addCriterion("PROJECT_START_TIME <=", value, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeIn(List<Date> values) {
            addCriterion("PROJECT_START_TIME in", values, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeNotIn(List<Date> values) {
            addCriterion("PROJECT_START_TIME not in", values, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeBetween(Date value1, Date value2) {
            addCriterion("PROJECT_START_TIME between", value1, value2, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectStartTimeNotBetween(Date value1, Date value2) {
            addCriterion("PROJECT_START_TIME not between", value1, value2, "projectStartTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeIsNull() {
            addCriterion("PROJECT_END_TIME is null");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeIsNotNull() {
            addCriterion("PROJECT_END_TIME is not null");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeEqualTo(Date value) {
            addCriterion("PROJECT_END_TIME =", value, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeNotEqualTo(Date value) {
            addCriterion("PROJECT_END_TIME <>", value, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeGreaterThan(Date value) {
            addCriterion("PROJECT_END_TIME >", value, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("PROJECT_END_TIME >=", value, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeLessThan(Date value) {
            addCriterion("PROJECT_END_TIME <", value, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeLessThanOrEqualTo(Date value) {
            addCriterion("PROJECT_END_TIME <=", value, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeIn(List<Date> values) {
            addCriterion("PROJECT_END_TIME in", values, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeNotIn(List<Date> values) {
            addCriterion("PROJECT_END_TIME not in", values, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeBetween(Date value1, Date value2) {
            addCriterion("PROJECT_END_TIME between", value1, value2, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andProjectEndTimeNotBetween(Date value1, Date value2) {
            addCriterion("PROJECT_END_TIME not between", value1, value2, "projectEndTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeIsNull() {
            addCriterion("open_time is null");
            return (Criteria) this;
        }

        public Criteria andOpenTimeIsNotNull() {
            addCriterion("open_time is not null");
            return (Criteria) this;
        }

        public Criteria andOpenTimeEqualTo(Date value) {
            addCriterion("open_time =", value, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeNotEqualTo(Date value) {
            addCriterion("open_time <>", value, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeGreaterThan(Date value) {
            addCriterion("open_time >", value, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("open_time >=", value, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeLessThan(Date value) {
            addCriterion("open_time <", value, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeLessThanOrEqualTo(Date value) {
            addCriterion("open_time <=", value, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeIn(List<Date> values) {
            addCriterion("open_time in", values, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeNotIn(List<Date> values) {
            addCriterion("open_time not in", values, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeBetween(Date value1, Date value2) {
            addCriterion("open_time between", value1, value2, "openTime");
            return (Criteria) this;
        }

        public Criteria andOpenTimeNotBetween(Date value1, Date value2) {
            addCriterion("open_time not between", value1, value2, "openTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeIsNull() {
            addCriterion("file_put_end_time is null");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeIsNotNull() {
            addCriterion("file_put_end_time is not null");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeEqualTo(Date value) {
            addCriterion("file_put_end_time =", value, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeNotEqualTo(Date value) {
            addCriterion("file_put_end_time <>", value, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeGreaterThan(Date value) {
            addCriterion("file_put_end_time >", value, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("file_put_end_time >=", value, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeLessThan(Date value) {
            addCriterion("file_put_end_time <", value, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeLessThanOrEqualTo(Date value) {
            addCriterion("file_put_end_time <=", value, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeIn(List<Date> values) {
            addCriterion("file_put_end_time in", values, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeNotIn(List<Date> values) {
            addCriterion("file_put_end_time not in", values, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeBetween(Date value1, Date value2) {
            addCriterion("file_put_end_time between", value1, value2, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andFilePutEndTimeNotBetween(Date value1, Date value2) {
            addCriterion("file_put_end_time not between", value1, value2, "filePutEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeIsNull() {
            addCriterion("answer_end_time is null");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeIsNotNull() {
            addCriterion("answer_end_time is not null");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeEqualTo(Date value) {
            addCriterion("answer_end_time =", value, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeNotEqualTo(Date value) {
            addCriterion("answer_end_time <>", value, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeGreaterThan(Date value) {
            addCriterion("answer_end_time >", value, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("answer_end_time >=", value, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeLessThan(Date value) {
            addCriterion("answer_end_time <", value, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeLessThanOrEqualTo(Date value) {
            addCriterion("answer_end_time <=", value, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeIn(List<Date> values) {
            addCriterion("answer_end_time in", values, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeNotIn(List<Date> values) {
            addCriterion("answer_end_time not in", values, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeBetween(Date value1, Date value2) {
            addCriterion("answer_end_time between", value1, value2, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andAnswerEndTimeNotBetween(Date value1, Date value2) {
            addCriterion("answer_end_time not between", value1, value2, "answerEndTime");
            return (Criteria) this;
        }

        public Criteria andTbRequiredIsNull() {
            addCriterion("tb_required is null");
            return (Criteria) this;
        }

        public Criteria andTbRequiredIsNotNull() {
            addCriterion("tb_required is not null");
            return (Criteria) this;
        }

        public Criteria andTbRequiredEqualTo(String value) {
            addCriterion("tb_required =", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredNotEqualTo(String value) {
            addCriterion("tb_required <>", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredGreaterThan(String value) {
            addCriterion("tb_required >", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredGreaterThanOrEqualTo(String value) {
            addCriterion("tb_required >=", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredLessThan(String value) {
            addCriterion("tb_required <", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredLessThanOrEqualTo(String value) {
            addCriterion("tb_required <=", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredLike(String value) {
            addCriterion("tb_required like", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredNotLike(String value) {
            addCriterion("tb_required not like", value, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredIn(List<String> values) {
            addCriterion("tb_required in", values, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredNotIn(List<String> values) {
            addCriterion("tb_required not in", values, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredBetween(String value1, String value2) {
            addCriterion("tb_required between", value1, value2, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andTbRequiredNotBetween(String value1, String value2) {
            addCriterion("tb_required not between", value1, value2, "tbRequired");
            return (Criteria) this;
        }

        public Criteria andZbFileGetIsNull() {
            addCriterion("zb_file_get is null");
            return (Criteria) this;
        }

        public Criteria andZbFileGetIsNotNull() {
            addCriterion("zb_file_get is not null");
            return (Criteria) this;
        }

        public Criteria andZbFileGetEqualTo(String value) {
            addCriterion("zb_file_get =", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetNotEqualTo(String value) {
            addCriterion("zb_file_get <>", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetGreaterThan(String value) {
            addCriterion("zb_file_get >", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetGreaterThanOrEqualTo(String value) {
            addCriterion("zb_file_get >=", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetLessThan(String value) {
            addCriterion("zb_file_get <", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetLessThanOrEqualTo(String value) {
            addCriterion("zb_file_get <=", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetLike(String value) {
            addCriterion("zb_file_get like", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetNotLike(String value) {
            addCriterion("zb_file_get not like", value, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetIn(List<String> values) {
            addCriterion("zb_file_get in", values, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetNotIn(List<String> values) {
            addCriterion("zb_file_get not in", values, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetBetween(String value1, String value2) {
            addCriterion("zb_file_get between", value1, value2, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andZbFileGetNotBetween(String value1, String value2) {
            addCriterion("zb_file_get not between", value1, value2, "zbFileGet");
            return (Criteria) this;
        }

        public Criteria andTbFilePutIsNull() {
            addCriterion("tb_file_put is null");
            return (Criteria) this;
        }

        public Criteria andTbFilePutIsNotNull() {
            addCriterion("tb_file_put is not null");
            return (Criteria) this;
        }

        public Criteria andTbFilePutEqualTo(String value) {
            addCriterion("tb_file_put =", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutNotEqualTo(String value) {
            addCriterion("tb_file_put <>", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutGreaterThan(String value) {
            addCriterion("tb_file_put >", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutGreaterThanOrEqualTo(String value) {
            addCriterion("tb_file_put >=", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutLessThan(String value) {
            addCriterion("tb_file_put <", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutLessThanOrEqualTo(String value) {
            addCriterion("tb_file_put <=", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutLike(String value) {
            addCriterion("tb_file_put like", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutNotLike(String value) {
            addCriterion("tb_file_put not like", value, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutIn(List<String> values) {
            addCriterion("tb_file_put in", values, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutNotIn(List<String> values) {
            addCriterion("tb_file_put not in", values, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutBetween(String value1, String value2) {
            addCriterion("tb_file_put between", value1, value2, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andTbFilePutNotBetween(String value1, String value2) {
            addCriterion("tb_file_put not between", value1, value2, "tbFilePut");
            return (Criteria) this;
        }

        public Criteria andContactIsNull() {
            addCriterion("Contact is null");
            return (Criteria) this;
        }

        public Criteria andContactIsNotNull() {
            addCriterion("Contact is not null");
            return (Criteria) this;
        }

        public Criteria andContactEqualTo(String value) {
            addCriterion("Contact =", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactNotEqualTo(String value) {
            addCriterion("Contact <>", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactGreaterThan(String value) {
            addCriterion("Contact >", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactGreaterThanOrEqualTo(String value) {
            addCriterion("Contact >=", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactLessThan(String value) {
            addCriterion("Contact <", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactLessThanOrEqualTo(String value) {
            addCriterion("Contact <=", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactLike(String value) {
            addCriterion("Contact like", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactNotLike(String value) {
            addCriterion("Contact not like", value, "contact");
            return (Criteria) this;
        }

        public Criteria andContactIn(List<String> values) {
            addCriterion("Contact in", values, "contact");
            return (Criteria) this;
        }

        public Criteria andContactNotIn(List<String> values) {
            addCriterion("Contact not in", values, "contact");
            return (Criteria) this;
        }

        public Criteria andContactBetween(String value1, String value2) {
            addCriterion("Contact between", value1, value2, "contact");
            return (Criteria) this;
        }

        public Criteria andContactNotBetween(String value1, String value2) {
            addCriterion("Contact not between", value1, value2, "contact");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdIsNull() {
            addCriterion("score_detail_file_id is null");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdIsNotNull() {
            addCriterion("score_detail_file_id is not null");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdEqualTo(Integer value) {
            addCriterion("score_detail_file_id =", value, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdNotEqualTo(Integer value) {
            addCriterion("score_detail_file_id <>", value, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdGreaterThan(Integer value) {
            addCriterion("score_detail_file_id >", value, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("score_detail_file_id >=", value, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdLessThan(Integer value) {
            addCriterion("score_detail_file_id <", value, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdLessThanOrEqualTo(Integer value) {
            addCriterion("score_detail_file_id <=", value, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdIn(List<Integer> values) {
            addCriterion("score_detail_file_id in", values, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdNotIn(List<Integer> values) {
            addCriterion("score_detail_file_id not in", values, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdBetween(Integer value1, Integer value2) {
            addCriterion("score_detail_file_id between", value1, value2, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andScoreDetailFileIdNotBetween(Integer value1, Integer value2) {
            addCriterion("score_detail_file_id not between", value1, value2, "scoreDetailFileId");
            return (Criteria) this;
        }

        public Criteria andShFlagIsNull() {
            addCriterion("sh_flag is null");
            return (Criteria) this;
        }

        public Criteria andShFlagIsNotNull() {
            addCriterion("sh_flag is not null");
            return (Criteria) this;
        }

        public Criteria andShFlagEqualTo(Integer value) {
            addCriterion("sh_flag =", value, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagNotEqualTo(Integer value) {
            addCriterion("sh_flag <>", value, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagGreaterThan(Integer value) {
            addCriterion("sh_flag >", value, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagGreaterThanOrEqualTo(Integer value) {
            addCriterion("sh_flag >=", value, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagLessThan(Integer value) {
            addCriterion("sh_flag <", value, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagLessThanOrEqualTo(Integer value) {
            addCriterion("sh_flag <=", value, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagIn(List<Integer> values) {
            addCriterion("sh_flag in", values, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagNotIn(List<Integer> values) {
            addCriterion("sh_flag not in", values, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagBetween(Integer value1, Integer value2) {
            addCriterion("sh_flag between", value1, value2, "shFlag");
            return (Criteria) this;
        }

        public Criteria andShFlagNotBetween(Integer value1, Integer value2) {
            addCriterion("sh_flag not between", value1, value2, "shFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagIsNull() {
            addCriterion("kb_flag is null");
            return (Criteria) this;
        }

        public Criteria andKbFlagIsNotNull() {
            addCriterion("kb_flag is not null");
            return (Criteria) this;
        }

        public Criteria andKbFlagEqualTo(Integer value) {
            addCriterion("kb_flag =", value, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagNotEqualTo(Integer value) {
            addCriterion("kb_flag <>", value, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagGreaterThan(Integer value) {
            addCriterion("kb_flag >", value, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagGreaterThanOrEqualTo(Integer value) {
            addCriterion("kb_flag >=", value, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagLessThan(Integer value) {
            addCriterion("kb_flag <", value, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagLessThanOrEqualTo(Integer value) {
            addCriterion("kb_flag <=", value, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagIn(List<Integer> values) {
            addCriterion("kb_flag in", values, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagNotIn(List<Integer> values) {
            addCriterion("kb_flag not in", values, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagBetween(Integer value1, Integer value2) {
            addCriterion("kb_flag between", value1, value2, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andKbFlagNotBetween(Integer value1, Integer value2) {
            addCriterion("kb_flag not between", value1, value2, "kbFlag");
            return (Criteria) this;
        }

        public Criteria andTypeIsNull() {
            addCriterion("`type` is null");
            return (Criteria) this;
        }

        public Criteria andTypeIsNotNull() {
            addCriterion("`type` is not null");
            return (Criteria) this;
        }

        public Criteria andTypeEqualTo(String value) {
            addCriterion("`type` =", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotEqualTo(String value) {
            addCriterion("`type` <>", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeGreaterThan(String value) {
            addCriterion("`type` >", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeGreaterThanOrEqualTo(String value) {
            addCriterion("`type` >=", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeLessThan(String value) {
            addCriterion("`type` <", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeLessThanOrEqualTo(String value) {
            addCriterion("`type` <=", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeLike(String value) {
            addCriterion("`type` like", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotLike(String value) {
            addCriterion("`type` not like", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeIn(List<String> values) {
            addCriterion("`type` in", values, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotIn(List<String> values) {
            addCriterion("`type` not in", values, "type");
            return (Criteria) this;
        }

        public Criteria andTypeBetween(String value1, String value2) {
            addCriterion("`type` between", value1, value2, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotBetween(String value1, String value2) {
            addCriterion("`type` not between", value1, value2, "type");
            return (Criteria) this;
        }
    }

    /**
     */
    public static class Criteria extends GeneratedCriteria {
        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}